home *** CD-ROM | disk | FTP | other *** search
/ Chip 2007 January, February, March & April / Chip-Cover-CD-2007-02.iso / Pakiet bezpieczenstwa / mini Pentoo LiveCD 2006.1 / mpentoo-2006.1.iso / livecd.squashfs / usr / include / captive / ldr_exports.h < prev    next >
C/C++ Source or Header  |  2006-05-01  |  4KB  |  102 lines

  1. /* $Id: ldr_exports.h,v 1.3 2003/10/28 18:58:46 short Exp $
  2.  * Include file for reactos ldr/ (loader) to be used from ke/exports.c of libcaptive
  3.  * Copyright (C) 2002 Jan Kratochvil <project-captive@jankratochvil.net>
  4.  * 
  5.  * This program is free software; you can redistribute it and/or modify
  6.  * it under the terms of the GNU General Public License as published by
  7.  * the Free Software Foundation; exactly version 2 of June 1991 is required
  8.  * 
  9.  * This program is distributed in the hope that it will be useful,
  10.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12.  * GNU General Public License for more details.
  13.  * 
  14.  * You should have received a copy of the GNU General Public License
  15.  * along with this program; if not, write to the Free Software
  16.  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
  17.  */
  18.  
  19.  
  20. #ifndef _CAPTIVE_LDR_EXPORTS_H
  21. #define _CAPTIVE_LDR_EXPORTS_H 1
  22.  
  23.  
  24. #include <glib/gtypes.h>
  25. /* NEVER include any captive/reactos include file as we are included
  26.  * from libcaptive/ke/exports.c which conflicts on any export symbol declaration.
  27.  */
  28.  
  29.  
  30. G_BEGIN_DECLS
  31.  
  32. /**
  33.  * captive_kernel_exports:
  34.  *
  35.  * Export complete libcaptive modules to reactos. It is done by *.def files used
  36.  * by dlltool(1) of Mingw32 compiler suite. We use native host OS compiler and
  37.  * we also have just a limited set of functions over reactos itself.
  38.  * We use our captive_ModuleList_add_builtin() to simulate PE headers exporting
  39.  * our symbols; this export simulation is invocated from this function.
  40.  *
  41.  * This function is generated automatically from #exports.captivesym file
  42.  * by #captivesym.pl script.
  43.  *
  44.  * Multiple calls of this function are forbidden. See also captive_kernel_patches().
  45.  *
  46.  * Returns: %TRUE if the export was successful.
  47.  */
  48. gboolean captive_kernel_exports(void);
  49.  
  50.  
  51. /**
  52.  * captive_kernel_patches_debug:
  53.  *
  54.  * Patches W32 libraries by libcaptive functions. It is done by *.def files used
  55.  * by dlltool(1) of Mingw32 compiler suite. We use native host OS compiler and
  56.  * we also have just a limited set of functions over reactos itself.
  57.  * We use our captive_ModuleList_patch() to modify existing module function
  58.  * tables generated from captive_ModuleList_add_builtin().
  59.  *
  60.  * This function is generated automatically from #exports.captivesym file
  61.  * by #captivesym.pl script.
  62.  *
  63.  * This function is used in --debug-messages mode as it also patches 'pass'
  64.  * functions to be successfuly debug dumped.
  65.  *
  66.  * Multiple calls of this function are forbidden. See also captive_kernel_exports().
  67.  *
  68.  * Returns: %TRUE if the export was successful.
  69.  */
  70. gboolean captive_kernel_patches_debug(void);
  71.  
  72.  
  73. /**
  74.  * captive_kernel_patches_nondebug:
  75.  *
  76.  * Function equivalent to captive_kernel_patches_debug() but it does not patch
  77.  * 'pass' functions as they are not needed to be traced if no --debug-messages
  78.  * was specified. See captive_kernel_patches_debug() for the description
  79.  * of this function.
  80.  *
  81.  * Returns: %TRUE if the export was successful.
  82.  */
  83. gboolean captive_kernel_patches_nondebug(void);
  84.  
  85.  
  86. struct captive_ModuleList_patchpoint {
  87.     guint8 *orig_w32_func;    /* direct pointer to W32 binary entry point */
  88.     guint8 *orig_w32_2ndinstr;    /* direct pointer to W32 binary second instruction after entry point */
  89.     void (*wrap_wrap_func)(void);    /* address of 'exports.c' debug-printing outer function */
  90.     guint8 orig_w32_func_byte;
  91.     guint8 orig_w32_2ndinstr_byte;
  92.     gboolean through_w32_func;    /* pass once through 'orig_w32_func' entry point without redirection to 'wrap_wrap_func' */
  93.     };
  94.  
  95. gboolean captive_ModuleList_add_builtin(const gchar *FullName_utf8,...);
  96. gboolean captive_ModuleList_patch(const gchar *FullName_utf8,...);
  97.  
  98. G_END_DECLS
  99.  
  100.  
  101. #endif /* _CAPTIVE_LDR_EXPORTS_H */
  102.